import classNames from 'classnames'
import { useEffect, useRef } from 'react'
import styles from './index.module.scss'

interface Props
  extends React.DetailedHTMLProps<
    React.TextareaHTMLAttributes<HTMLTextAreaElement>,
    HTMLTextAreaElement
  > {
  className?: string
  maxLength?: number
  value?: string
}
export default function Textarea({ className, value = '', maxLength = 100, ...rest }: Props) {
  // 获取原生 textarea 标签
  const textareaRef = useRef<HTMLTextAreaElement>(null)

  useEffect(() => {
    // 🔔  ?. 属性访问安全的写法：表示前面的非空，再往后调用方法或属性。
    // null.aa     报错
    // null?.aa    不报错
    textareaRef.current?.setSelectionRange(-1, -1)
  }, [])

  return (
    <div className={styles.root}>
      {/* 文本输入框 */}
      <textarea
        ref={textareaRef}
        {...rest}
        value={value}
        maxLength={maxLength}
        className={classNames('textarea', className)}
      />
      {/* 当前字数/最大允许字数 */}
      <div className='count'>
        {value.length}/{maxLength}
      </div>
    </div>
  )
}
